Группировка с условием на всю группу | GROUP BY HAVING

Редактировал(а) Alexandr Fokin 2023/12/16 14:12


SELECT
    person_id
FROM MyTable
GROUP BY person_id
HAVING 3 = (
   MAX(CASE pet WHEN 'dog' THEN 1 ELSE 0 END)
+   MAX(CASE pet WHEN 'cat' THEN 1 ELSE 0 END)
+   MAX(CASE pet WHEN 'tiger ' THEN 1 ELSE 0 END)
)

С помощью CASE-WHEN и MAX можно выбрать только те группы, в которых есть указанное значение(я). (Хотя бы один раз)

Group by having at least one of each item
https://stackoverflow.com/questions/32122777/group-by-having-at-least-one-of-each-item

Теги: